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METHOD AND APPARATUS FOR MERGING ACCOUNTING RECORDS TO 
MINIMIZE OVERHEAD 

1. Field of the Invention: 

The present invention relates generally to a method and apparatus for merging 
accounting records to minimize overhead. In particular, the present invention is 
directed to a method and apparatus for merging accounting records for traffic flowing 
between a wireless communication network and a packet switched data network. 

2. Background of the Invention: 

As wireless communication becomes more highly used in our society, people 
look for more features in their wireless communication service providers and 
equipment. Once feature that is slowly becoming more prevalent is the ability to 
transmit and receive data over wireless communication links. With this feature, 
persons using wireless digital equipment may send and receive electronic mail, "surf 
the Internet, and even download computer applications. Virtually, any function that 
may be performed with a computer using a land-line wired connection to the Internet, 
may one day be performed over wireless communication links. 

As a result, there is a need to be able to perform accounting of usage of 
wireless communication links to obtain access to data networks, such as the Internet. 
However, such accounting is typically performed by the separate networks, i.e. there 
are accounting records for the wireless communication network and other accounting 
records for the data network. These two sets of accounting records may be difficult to 
correlate. Thus, it would be beneficial to have an apparatus and method for merging 
accounting records for traffic flowing between wireless communication networks and 
data packet switched networks. 
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SUMMARY OF THE INVENTION 

The present invention provides a method and apparatus for merging 
5 accounting records to minimize overhead. The method and apparatus accumulate 
accounting information for data transmissions between a wireless communication 
device and a host on a data network. The method and apparatus are capable of 
accumulating accounting information for short data bursts and for active traffic 
channel transmissions such that an accounting messages is sent to an accounting 

1 0 server only when transitions from short data burst transmission or active traffic 

channel transmission to another state are encountered. Thus, accounting information 
for a plurality of sequential short data bursts and/or active traffic channel 
transmissions are accumulated. This reduces the number of accounting messages sent 
to an accounting server and eliminates race conditions that may be encountered by 

1 5 sequential short data bursts . 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The novel features believed characteristic of the invention are set forth in the 
5 appended claims. The invention itself, however, as well as a preferred mode of use, 
further objectives and advantages thereof, will best be understood by reference to the 
following detailed description of an illustrative embodiment when read in conjunction 
with the accompanying drawings, wherein: 

Figure 1 is an exemplary block diagram of a distributed data processing system 
10 in which the present invention may be implemented; 

Figure 2 is an exemplary block diagram illustrating the components of the 
bridge server in accordance with the present invention; 

Figure 3 is an exemplary table diagram of the parameters of a setup airlink 
record in accordance with the present invention; 
1 5 Figure 4 is an exemplary table diagram of the parameters of a connection 

release airlink record in accordance with the present invention; 

Figure 5 is an exemplary table diagram of the parameters of an active start 
airlink record in accordance with the present invention; 

Figure 6 is an exemplary table diagram of the parameters of a active stop 
2 0 airlink record in accordance with the present invention; 

Figure 7 is an exemplary table diagram of the parameters of a SDB airlink 
record in accordance with the present invention; 

Figures 8 A and 8B are an exemplary table diagram of the parameters that 
make up a usage data record in accordance with the present invention; 

2 5 Figure 9 is an exemplary timing diagram illustrating the messages sent when 

a start and stop record are sent for each SDB to the accounting server; 

Figure 10 is an exemplary timing diagram illustrating the messages sent when 
SDB accounting information is accumulated for a plurality of SDBs; 

Figure 11 is an exemplary timing diagram illustrating the messages sent when 

3 0 a start and stop record are sent for each active transmission; 
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Figure 12 is an exemplary timing diagram illustrating the messages sent when 
active transmission accounting information is accumulated for a plurality of active 
transmissions; and 

Figure 13 is a flowchart outlining an exemplary operation of the present 
5 invention. 
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DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS 

Figure 1 is an exemplary diagram of a distributed data processing system in 
5 which the present invention may be implemented. As shown in Figure 1, the 
distributed data processing system 100 includes a data network 110, a wireless 
communication network 120, a bridge server 150 and an accounting server 160. 

The data network 110 provides communication pathways for a plurality of 
computing devices, such as server devices 112 and 114 and client device 116. The 
1 0 data network 110 may be any type of packet data network, such as a local area 

network (LAN), wide area network (WAN), an intranet, the Internet, and the like. In 
a preferred embodiment of the present invention, the data network 110 is considered 
to be the Internet. 

The Internet is a worldwide collection of networks and gateways that use the 
1 5 TCP/TP suite of protocols to communicate with one another. At the heart of the 

Internet is a backbone of high-speed data communication lines between major nodes 
or host computers, consisting of thousands of commercial, government, educational, 
and other computer systems, that route data and messages. 

The wireless communication network 120 provides communication pathways 
2 0 for a plurality of wireless communication devices, such as personal digital assistant 
(PDA) 122, laptop computer 124, cellular telephones, and the like. The wireless 
communication network 120 may be any type of wireless communication network, 
such as a cellular network, satellite network, radio network, and the like. In a 
preferred embodiment of the present invention, the wireless communication network 

2 5 120 is a wireless packet data network, such as a digital cellular communication 

network. 

The cellular communication network 120 is a network of base stations 126 
and 128 which are used to communicate with wireless communication devices 122 
and 124 using radio communications. The wireless communication devices 122 and 

3 0 124 support TCP/IP, allowing the wireless communication devices 122 and 124 to 
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have access to the Internet 110. For example, the wireless communication devices 
122 and 124 may communicate using the PCS band, which is a radio spectrum that 
was auctioned off by the U.S. Government in the mid 1990s. 

The networks 110 and 120 are linked with one another via the bridge server 
5 150. The bridge server 150 accepts digital communication signals from either the 
data network 110 or the wireless communication network 120, formats the signal for 
the other network, and forwards the digital communication signal to the other 
network. By linking the two networks 110 and 120 via the bridge server 150, a user 
of a wireless communication device, such as laptop computer 124, may send and 
1 0 retrieve information to and from computing devices linked to the data network 110. 
For example, a user of the laptop computer 124 may receive Web pages from the data 
network 110 and send electronic mail messages to computing devices linked to the 
data network 110. 

While Figure 1 shows the bridge server 150 being disposed between the 
1 5 wireless communication network 120 and the data network 110, the invention is not 
limited to such. Rather, the bridge server 150 may be a packet data serving node 
(PDSN) in either the wireless communication network 120 or the data network 110. 
Furthermore, the processes of the present invention may be distributed amongst a 
plurality of bridge servers 150. 
2 0 In addition, the bridge server 150 collects accounting information for billing 

and statistical purposes. The accounting information includes sufficient information 
for determining the services provided to the user, the amount of time on the networks 
110 and 120, the number of data packets transmitted, and/or the like. The accounting 
information is obtained from the wireless communication network 120 and the data 

2 5 network 110. The accounting information obtained from the wireless communication 

network 120 includes wireless specific parameters and the accounting information 
from the data network 110 includes data network specific parameters. The 
accounting information obtained from the wireless communication network 120 is 
obtained from the base station controllers of the wireless communication network 

3 0 120. The bridge server 150 itself maintains the accounting information for the data 
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network 110. This accounting information is forwarded to an accounting server 160 
for proper accounting procedures. 

The accounting server 160 may be, for example, a Remote Authentication 
Dial-In User Service (RADIUS) server or the like. RADIUS is an access control 
5 protocol developed by Livingston Enterprises that uses a client-server based protocol 
for collecting accounting information. RADIUS is designed to work with dialup 
wire-line communications. In this case, a call session is initiated (RADIUS start) and 
the call is established for a certain duration. When the call is terminated, the call 
session is terminated (RADIUS stop). 
Cr 1 0 In a wireless communication environment, a mobile communication device 

starts a session and then has traffic channels established intermittently. Finally at 
some point, the mobile communication device either ends the session gracefully by 
sending a session termination command or just disappears and the wireless 
communication system performs "clean-up" procedures after a predetermined amount 

15 of no activity. Thus, if RADIUS were applied to conventional wireless 

communication environments, the result would require many RADIUS start and stop 
messages for every traffic channel setup and teardown even though the session itself 
has not been terminated. The present invention provides a mechanism by which 
excessive start and stop messages are avoided during a communication session. 

2 0 In a preferred embodiment, the bridge server 150 collects accounting 

information from the data network 110 and the wireless communication network 120 
and merges the accounting information into data structures, called usage data records 
(hereafter referred to as UDRs), that are formatted to the RADIUS protocol. The 
UDRs are sent to the accounting server 160 which then provides positive 

2 5 acknowledgment that the UDRs were received correctly. The bridge server 150 will 

formulate one UDR per session per wireless communication device. If there are 
multiple IP addresses for the same session, however, the bridge server 150 will 
formulate multiple UDRs. 

The accounting server 160 maintains the UDR until the UDR is removed by 

3 0 an operator billing system. The process by which an operator billing system removes 
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UDRs from an accounting server 160 is generally known in the art and will therefore, 
not be described in further detail. 

The bridge server 150 obtains the wireless network specific parameters from 
messages sent to the bridge server 150 from the wireless communication network 
120. These messages are sent from Packet Control Functions (PCFs) (described in 
Technical Service Bulletin (TSB)-l 15, available from the Telecommunications 
Industry Association), or more generally, base station controllers (BSCs), in the 
wireless communication network associated with the base stations 126 and 128. 
Once the bridge server 150 merges the accounting information from the wireless 
communication network 120 with the accounting information from the data network 
110, the resulting UDR information is sent to the accounting server 160 as an 
accounting request message, such as a RADIUS accounting-request message. 

While the embodiment shown in Figure 1 depicts a single data network 110 
and a single wireless communication network 120, the invention is not limited to 
such. Rather, the data network 110 and the wireless communication network 120 
may be comprised of one or more networks of the same or different types. In 
addition, while Figure 1 shows the accounting server 160 being linked directly to the 
bridge server 150, the invention is not limited to such. Rather, the accounting server 
may be incorporated into the bridge server 150, linked to the bridge server 150 via the 
data network 1 10 or wireless communication network 120, or the like. Furthermore, 
the functions of the bridge server 150 and the accounting server 160 may be 
distributed across a plurality of bridge servers 150 and accounting servers 160 linked 
to the data network 110 and the wireless communication network 120. 

Figure 2 is an exemplary diagram of the bridge server 150 according to the 
present invention. As shown in Figure 2, the bridge server 150 includes a network 
interface 210, a logic controller 220, octet buffer 230, and accounting controller 240. 
Data is passed between the wireless communication network 120 and the data 
network 110 via the network interface 210 and communication links 250 and 260. 
Data received is stored in the octet buffer 230 until transmitted to the receiving 



Docket No. 11440RRUS02U 



9 



Express Mail No. EL356874475US 



network 110 or 120. An octet is an eight-bit storage unit. In the international 
community, octet is often used instead of byte. 

Typically, wireless communication networks use octets for the transmission of 
data. Packet switched networks, such as the Internet, use data packets for 
5 transmission which may be comprised of multiple octets. Thus, when data packets 
are received from the data network 110, which in the preferred embodiment is the 
Internet, the data packets must first be broken down into octets. The breakdown of 
the data packets into octets is performed by the network interface 210 and logic 
controller 220 which then stores the octets in the octet buffer 230. The octets stored 
10 in the octet buffer 230 may then be transmitted to the wireless communication 
network 120 via the communication link 250. 

Similarly, when data is received from the wireless communication network 
120, the data is in the form of octets. The octets are stored in the octet buffer 230 
until there is sufficient number of octets to form a data packet, as determined by the 
1 5 logic controller 220. Once there are sufficient octets in the octet buffer 230, a data 
packet is transmitted to the data network 110 via the communication link 260. 

In addition to the data transmitted via the corrimunication links 250 and 260, 
accounting messages are sent to the accounting controller 240 from the wireless 
communication network via the control channel 270. The accounting messages sent 
2 0 from the wireless communication network 120 to the accounting controller 240 are 
called airlink messages. 

The data network accounting information is collected by the bridge server 150 
itself. The bridge server 150 monitors octets flowing from the octet buffer and 
collects all other parameters not in airlink records from the network interface 210. 

2 5 The airlink messages are comprised of one or more airlink records. 

The wireless communication system 120 generates one of five types of airlink 
records: 

1) a connection setup record when the wireless communication 

network establishes a communication connection to the data 

3 0 network; 
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2) a connection release record when the wireless communication 
network release the communication connection with the data 
network; 

3) an active start record when the wireless communication device 
starts to use traffic channel(s); 

4) an active stop record when the wireless communication device stops 
using traffic channel(s); and 

5) a short data burst (SDB) record when a short data burst is 
exchanged with the wireless communication device. 

The receipt of a session setup airlink record instructs the accounting controller 240 to 
establish a usage data record (UDR) for a session. The UDR is established based on a 
session identifier, wireless communication device identifier, and the like. Thereafter, 
the airlink messages received by the accounting controller 240 are added to the UDR 
based on the session identifier that identifies the particular session with which the 
airlink message is associated. After a session release airlink record is received, the 
UDR is transmitted to an account server, such as account server 170. If the account 
server 170 returns an acknowledgment message, the UDR is removed from the 
accounting controller 240, otherwise the UDR is retransmitted until an 
acknowledgment message is received. 

The following table diagrams will illustrate parameters for each of the various 
airlink messages that are transmitted by the wireless communication network 120 to 
the accounting controller 240 along with the resulting UDR that is sent to the 
accounting server. In each table, where appropriate, an item identifier is provided. 
The item identifiers in lower case correspond to the upper case item identifiers in the 
resulting UDR. Also in each table, a maximum payload length and format are 
provided. The maximum payload represents the maximum length of the field in the 
airlink message. The format represents the format of the parameter, e.g., integer, 
string, IP address, and the like. 
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Figure 3 is an exemplary table diagram of the parameters that make up a 
session setup airlink record. As shown in Figure 3, the parameters include an airlink 
record type 310, a session identifier 320, a wireless communication device (referred 
to in Figure 3 as a mobile station (MS)) identifier 330, a serving Packet Control 
5 Function (PCF) identifier 340, and a base station (BS) and/or mobile service center 
(MSC) identifier 350. The airlink record type 310 identifies the type of airlink 
message as being a session setup airlink record. The session identifier 320 is a unique 
identifier assigned to the session. The wireless communication device identifier 330 
is a unique identifier assigned to the particular wireless communication device. The 

1 0 serving PCF identifier 340 is a unique identifier assigned to the PCF and the base 

station/mobile service center identifier 350 is a unique identifier assigned to the base 
station/mobile service center handling the communication in the wireless 
communication network 120. 

This information is used by the accounting controller 240 to establish a UDR 

1 5 for the particular session. Once the session setup airlink record is received by the 
accounting controller 240, a UDR for the session is created and information for the 
session is maintained in the UDR until a session release airlink record is received. 

Figure 4 is an exemplary table diagram of the parameters that make up a 
session release airlink record. The session release airlink record only contains an 

2 0 airlink record type 410 and a session identifier 420. The airlink record type 410 
designates the airlink record as a connection release airlink record. The session 
identifier 420 identifies the session that has been ended. Once the session release 
airlink record is received, the accounting controller 240 sends the UDR to the 
accounting server. 

2 5 Between the sending of the session setup airlink record and the session release 

airlink record, other interim airlink records are sent to the accounting controller 240 
to designate different types of data communication that are occurring on the traffic 
channels. Once such airlink record is the active start airlink record. The active start 
airlink record designates to the accounting controller 240 that data transmission 

3 0 across the traffic channel has begun. 
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Figure 5 is an exemplary table diagram of the parameters that make up an 
active start airlink record. As shown in Figure 5, the active start airlink record 
includes an airlink record type 505, a session identifier 510, a user zone 515, a 
forward Mux option 520, a reverse Mux option 525, a forward fundamental rate 530, 
5 a reverse fundamental rate 535, and a service option 540, a forward traffic type 545, a 
reverse traffic type 550, a fundamental frame size 555, a forward fundamental RC 
560, a reverse fundamental RC 565 and an airlink quality of service 570. The airlink 
record type 505 identifies which type of airlink record it is (start, stop, SDB, 
connection setup, connection release). The session identifier 510 is a unique 

1 0 identifier for each wireless network-data network connection. The other parameters 
515-565 are all defined parameters in standard TIA/EIA-2000 available from the 
Telecommunication Industry Association/Electronics Industry Association. The 
airlink quality of service 570 has 16 levels of priority values designated various levels 
of quality of service. These 16 levels of priority can also be found in standard 

1 5 TIA/EIA-2000. The active start airlink record informs the accounting controller 240 
of the start of data transmission across the traffic channel. 

Figure 6 is an exemplary table diagram illustrating the parameters of an active 
stop airlink record. As shown in Figure 6, the active stop airlink record includes an 
airlink record type 610, a session identifier 620 and an active connection time in 

2 0 seconds 630. The airlink record type 610 identifies the airlink record as an active 
stop airlink record. The session identifier 620 identifies the session. The active 
connection time in seconds 630 informs the accounting controller 240 of the number 
of seconds the traffic channel was active with data from the session. 

In addition to transmitting data over the traffic channels in a normal operation 

2 5 as handled by the above start and stop airlink records, data may be transmitted as 

short data bursts (SDBs). A short data burst is a burst of data that lasts for a very 
short time rather than a consistent stream of data and is sent over common traffic 
channels instead of dedicated traffic channels as specified in TIA/ELA-2000. 

Figure 7 is an exemplary table diagram illustrating the parameters of a short 

3 0 data burst (SDB) airlink record. As shown in Figure 7, the SDB airlink record 
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includes an airlink record type 710, a session identifier 720, a mobile 
originated/mobile terminated indicator 730, and an SDB octet count 740. The airlink 
record type 710 identifies the airlink record as a SDB airlink record. The session 
identifier 720 identifies the session. The airlink record type 710 identifies the airlink 
5 record as a SDB airlink record. The session identifier 720 identifies the session to 
which the SDB airlink record belongs. The mobile originated/mobile terminated 
indicator 730 indicates whether or not the SDB was received or sent from the wireless 
communication device, i.e. the mobile station and is used to increment forward 
direction or reverse direction SDB octet counts. The SDB octet count 740 identifies 

1 0 the number of octets of data sent during the short data burst. 

Figures 8A and 8B are an exemplary table diagram illustrating the parameters 
of a usage data record (UDR) according to the present invention. The various 
parameters of the UDR are populated by the information provided in the various 
airlink records described above. 

15 As shown in Figure 8, the UDR 800 includes a mobile station identifier 

(MSID) 810 which identifies the particular wireless communication device or mobile 
station. In addition to the MSID 810, the UDR 800 further includes user identifiers 
820, session identifiers 825, infrastructure identifiers 830, zone identifiers 840, 
session status identifiers 850, session activity identifiers 860, special billing 

2 0 instructions identifiers 870 and quality of service identifiers 880. 

The user identifiers 820 include an Internet Protocol (IP) address and network 
access identifier (NAI). The IP address is the IP address assigned to the mobile 
station upon initiation of an IP connection with the data network. The NAI is of the 
type "user@domain" thereby identifying the user and home network of the mobile 

2 5 station. 

The session identifiers 825 include an account session identifier and a 
correlation identifier. The account session identifier is a unique identifier created by 
the accounting controller to allow start and stop records to be matched in a log file. 
The correlation identifier is an identifier that correlates the accounting sessions 



Docket No. 11440RRUS02U 



14 



Express Mail No. EL356874475US 



authorized for the NAI. Thus the correlation identifier allows multiple accounting 
sessions for a single NAI. 

The infrastructure identifiers 830 includes a mobile IP (MIP) home agent 
(HA) identifier, a foreign agent (FA) identifier, a serving PCF identifier, and a 
5 BS/MSC identifier. The MIP home agent identifier is the IP address of the home 
agent. The home agent and foreign agent are defined by the Internet Engineering 
Task Force (IETF) in document RFC 2002. The FA identifier is the IP address of the 
foreign agent handling the communication. The serving PCF identifier is the TP 
address of the serving PCF. The base station (BS)/mobile station controller (MSC) 

1 0 identifier is the System ID/Network ID (SID/NID) as defined in TIA/EIA-2000 

concatenated with a two octet BSC ID of the base station/mobile station controller 
handling the communication. 

The zone identifier identifies the tiered services user zone of the mobile 
station. User zones are arbitrary geographic regions defined by the service provider. 

1 5 Charge rates may differ in different user zones. Thus, there may be tiered service 
user zones requiring different charge rates during a communication. 

The session status indicators 840 contains a number of parameters including 
forward Mux option, reverse Mux option, forward fundamental rate, reverse 
fundamental rate, service option, forward traffic type, reverse traffic type, 

2 0 fundamental frame size, forward fundamental RC, reverse fundamental RC, IP 

technology, compulsory tunnel indicator, and release indicator. The forward Mux 
option, reverse Mux option, forward fundamental rate, reverse fundamental rate, 
service option, forward traffic type, reverse traffic type, fundamental frame size, 
forward fundamental RC, reverse fundamental RC are defined in TIA/EIA-2000. IP 

2 5 technology is defined as Simple IP or Mobile IP as defined in TIA/EIA-835, also 

available from the Telecommunications Industry Association/Electronics Industry 
Association. The compulsory tunnel indicator and release indicator are also both 
defined in TIA/EIA-835. 

The session activity indicators 860 include data octet count for when the 

3 0 mobile station is the termination point, data octet count for when the mobile station is 
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an origination point, bad Point-to-Point Protocol (PPP) frame count, event time, 
active time, number of active transitions, SDB octet count for when the mobile station 
is the termination point, SDB octet count for when the mobile station is the 
origination point, number of SDB transmissions when the mobile station is the 
5 termination point, and number of SDB transmission when the mobile station is the 
origination point. Each of these parameters will be address individually below. 

The data octet count for when the mobile station is the termination point 
provides a total number of data octets received by the mobile station. The data octet 
count for when the mobile station is the origination point is a total number of data 
1 0 octets sent by the mobile station. 

The bad PPP frame count is the total number of bad PPP frames encountered. 
Point-to-Point Protocol (PPP) is a data link protocol that provides dial-up access over 
serial lines. A frame is a fixed block of data transmitted as a single entity. A frame is 
also sometimes referred to as a data packet. Thus, the bad PPP frame count provides 
15 a total number of bad packets received over a dial-up access link. 

The event time indicates the start of an accounting session or stop of an 
accounting session if part of a start airlink record or stop airlink record. In an interim 
record, the event time indicates the time of the event that triggered the interim 
message. 

2 0 The active time indicates the total active connection time on the traffic 

channel(s) in seconds. The number of active transitions is the total number of non- 
active to active transitions. The SDB octet count is the total number of octets sent or 
received via short data bursts. The number of short data bursts is the total number of 
short data burst transactions in which data was either sent or received. 

2 5 The special billing instructions identifier 870 identifies an alternate entity for 

which data session usage may be billed. For example, the special billing instructions 
identifier 870 may designate a credit card number, telephone number account, 
Internet Service Provider (ISP) account, or the like, to which session usage may be 
billed. 
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The quality of service identifiers 880 include an IP quality of service (QoS), 
an interconnection IP network provider identifier, an interconnecting IP network 
service QoS, and an airlink QoS. The IP QoS identifies the level of transmission 
quality at the IP layer. The IP QoS specifically refers to Diff-Serv codepoints as 
5 defined by the IETF. The interconnection IP network provider identifier identifies 
the IP network which connects the wireless communication network with the 
destination of the communication. The interconnecting IP network service QoS 
identifies the QoS offered by the IP network which connects the wireless 
communication network with the destination of the communication. The airlink QoS 

1 0 identifies level of transmission quality over the air as defined by TIA/EIA-2000. 

There are a number of accounting triggers that are received by the accounting 
controller. These triggers include, but are not limited to, the establishment or tear- 
down of a wireless network/data network connection, the arrival of forward or reverse 
direction user data, the reception of active start and active stop records, the reception 

15 of a short data burst airlink record, and the expiration of an interim timer. 

As mentioned above, data may be sent over an active traffic channel or 
through the use of short data bursts. A start and stop airlink record may be sent for 
each non-active to active transition and also for each short data burst. However, this 
may lead to a race condition as illustrated by the following example. 

2 0 Assume the mobile station is at first in a dormant state. Thereafter, data 

network originated data flows into the bridge server and is forwarded to the wireless 
communication network. The wireless communication network starts to transmit the 
data as a short data burst. As the short data burst is transmitted, more data arrives in 
the data network and is sent to the wireless communication network. The wireless 

2 5 communication network completes the short data burst and sends an indication to the 

data network of the completion of the short data burst. The data network sends start 
and stop airlink records with the total octet counts of both short data bursts. The 
wireless communication network transmits the second short data burst and sends an 
indication to the data network that the short data burst has completed. The data 

3 0 network needs to send another set of start and stop airlink records, however the octet 
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counts have been zeroed out due to the previous start and stop airlink records having 
been sent. 

In addition, the number of accounting messages sent to the accounting server 
is greatly increased with increased usage of short data bursts. This is because each 
5 short data burst generates a start and stop airlink record. Since many short data bursts 
must be used to send the same amount of data as a typical active traffic channel 
transmission, the short data bursts generate a much larger number of accounting 
records than an equivalent active traffic channel transmission. 

In a preferred embodiment of the present invention, the above problems are 
1 0 addressed by accumulating accounting information over a series of short data bursts 
and a series of active traffic channel transmissions. In this way, the number of airlink 
records generated is reduced and the race conditions are eliminated. The preferred 
embodiment will now be described with reference to the following timing diagrams. 
Figure 9 is an exemplary timing diagram of the present invention when 
1 5 generating a start/stop airlink record for each short data burst. For purposes of 
illustration, only data flowing from the data network to the mobile station will be 
described in detail. However, those of ordinary skill in the art will appreciate the 
advantages of the present invention in either a sending or receiving mode. 

As shown in Figure 9, the operation starts with the mobile station (MS) being 
2 0 dormant (Tl). At some time later, data enters the data network and is sent to the 
wireless communication network via the bridge server. The accounting controller 
increments the received octet count by the number of octets received (T2). The data 
is transmitted as a short data burst in the wireless communication network. At the 
same time, more data enters the data network and is sent to the wireless 

2 5 communication network. The octet counts for the number of octets received, number 

of octets sent, number of octets sent in short data burst, and the like, are incremented 
in the accounting controller (T3). Start and stop airlink records are sent to the 
accounting server identifying the number of octets sent. The number of octets in the 
accounting controller are then decremented by the number of octets identified in the 

3 0 start and stop airlink records (T4). 
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It is assumed, in this example, that the number of octets received while the 
short data burst is being sent is above a predetermined threshold. Once this threshold 
is exceeded, the WCS determines that the data should be sent over an active traffic 
channel. As a result, an active start airlink record is sent to the accounting controller 
5 (T5). At some time thereafter, the active traffic channel goes dormant and an active 
stop airlink record is sent to the accounting controller (T6). 

Figure 10 illustrates a preferred embodiment of the present invention in 
which short data bursts (SDBs) are accumulated over an interval. As shown in 
Figure 10, the mobile station (MS) is initially dormant (Tl). Thereafter, data is 
1 0 received by the data network and sent to the wireless communication network. The 
total number of octets received is then incremented in the accounting controller (T2). 
The data received is sent to the mobile station as a first short data burst. While the 
first short data burst is being sent, more data is received by the data network and sent 
to the wireless communication network. The total number of octets received is 
1 5 incremented in the accounting controller by the amount of the received data (T3). 

A second SDB is transmitted to the MS. An airlink record identifying the 
transmission of the first SDB is sent by the wireless communication network to the 
accounting controller. The accounting controller increments the number of SDBs by 
1 and the total number of SDB octets by the number of octets in the first SDB. 
2 0 Meanwhile, more data is being received by the data network and sent to the wireless 
communication network. The total number of octets received is then incremented by 
the number octets in the second set of received data (T4). 

The third set of data is transmitted as a third SDB to the MS. An airlink 
record identifying the transmission of the second SDB is sent by the wireless 

2 5 communication network to the accounting controller. The accounting controller 

increments the number of SDBs by 1 and the total number of SDB octets by the 
number of octets in the second SDB. Meanwhile, more data is being received by the 
data network and sent to the wireless communication network. The total number of 
octets received is then incremented by the number of octets in the third set of received 

3 0 data (T5). 
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An interim timer expires (T6). This is a configurable timer the operator sets 
to make sure accounting data does not "sit too long" in the bridge server 150 without 
being sent to the accounting server 160. This avoids the case where the bridge server 
150 goes down and all unsent accounting data would be lost. With the present 
5 invention after a certain interval, the interim timer fires to make sure a snapshot of the 
accounting data is sent to the accounting server 160. 

The wireless communication network sends an airlink record identifying the 
transmission of the third SDB. The accounting controller increments the number of 
SDBs by 1 and the total number of SDB octets by the number of octets in the third 

1 0 SDB. Meanwhile, more data is being received by the data network and sent to the 
wireless communication network. The total number of octets received is then 
incremented by the number of octets in the fourth set of received data (T7). 

Because the fourth set of received data meets a predetermined criteria, it is 
assumed that the wireless communication network activates the traffic channel for 

1 5 transmission to the mobile station. As a result, an active start airlink record is sent to 
the accounting controller. Meanwhile more data is being received in the data network 
for transmission to the mobile station. A start record is sent to the accounting server 
identifying the number of SDBs, total number of SDB octets and the octet count. The 
octet count is then incremented by the number of octets received (T8). 

2 0 Transmission of data to the mobile station is then over an active traffic 

channel until the mobile station goes dormant. At this time, an active stop airlink 
record is sent from the wireless communication network to the accounting controller. 
The accounting controller sends a stop record to the accounting server identifying the 
number of SDBs, total number of SDB octets and the octet count. This information is 

2 5 sent again since the stop record must be cummulative and contain all the information 

since the start record. In other words, the start record opens an accounting entry and 
the stop record reports all the final counts. The total number of SDBs, SDB octets 
and the octet count are then cleared (Tn). 

Thus, with the present invention, the number of messages sent to the 

3 0 accounting server is minimized by accumulating short data burst information over an 
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interval containing a plurality of short data bursts. Thus, rather than sending eight 
accounting messages to the accounting server in the above example, only four 
messages are sent, thereby reducing the number of required accounting messages to 
half. In addition, the race condition that may be encountered when sending 
5 accounting messages for each short data burst are eliminated due to the accumulation 
of short data burst information over a time interval. The time interval in this example 
is the period starting with the first short data burst and ending when data transmission 
over an active traffic channel is started. 

As mentioned above, the accumulation of accounting information is not 

1 0 limited to short data burst information. Rather, benefits may be obtained from 
accumulating accounting information over an interval of active traffic channel 
transmissions. The following timing diagrams will illustrate the use of accumulation 
when applied to active traffic channel transmissions. 

Figure 11 is an exemplary timing diagram of the present invention when 

1 5 sending accounting messages for each active traffic channel transmission. As shown 
in Figure 11, the mobile station is initially in a dormant state (Tl). Thereafter, data is 
received in the data network and sent to the wireless communication network via the 
bridge server. The accounting controller in the bridge server increments the octet 
count by the number of octets received (T2). 

2 0 Because the data received meets a predetermined criteria, the wireless 

communication network is assumed to initiate an active traffic channel and an active 
start airlink record is sent to the accounting controller. The accounting controller then 
sends a start record to the accounting server. Meanwhile, more data is received by 
the data network for transmission to the wireless communication network. The octet 

2 5 count is incremented by the amount of this additional data (T3). 

At some time later, the mobile station goes dormant and an active stop airlink 
record is sent to the accounting controller. The accounting controller sends a stop 
record to the accounting server identifying the number of octets. The octet count is 
zeroed by the accounting controller (T4). 
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Thereafter, more data is received by the data network for transmission to the 
wireless communication network. The accounting controller increments the octet 
count by the amount of data received (T5). Because the data satisfies a 
predetermined criteria, the wireless communication network opens an active traffic 
5 channel to the mobile station for transmission of the data. As a result, an active start 
airlink message is sent to the accounting controller. The accounting controller sends 
a start record to the accounting server (T6). 

At some time later, the mobile station goes dormant and an active stop airlink 
message is sent to the accounting controller. The accounting controller sends a stop 
1 0 record to the accounting server with the octet count and zeroes the octet count (T7). 
Thus, when sending start and stop messages to the accounting server for each active 
traffic channel transmission, the number of messages sent in the above example is 
four. 

Figure 12 shows an example of a preferred embodiment of the present 
1 5 invention when accumulating active traffic channel accounting information over a 

plurality of active traffic channel transmissions. As shown in Figure 12, when a PPP 
session is initiated and the wireless communication network opens an active traffic 
channel to the mobile station for transmitting data from the data network, an active 
start airlink record is sent to the accounting controller. The accounting controller then 
2 0 sends a start record to the accounting server (Tl). 

At some time later, the mobile station goes dormant and an active stop airlink 
record is sent to the accounting controller identifying the time the active traffic 
channel was utilized. The accounting controller increments a total active time by the 
amount of the active time received from the wireless communication network (T2). 
2 5 Thereafter, more data is received by the data network for transmission to the 

wireless communication network. The octet count is incremented by the accounting 
controller (T3). The wireless communication network opens an active traffic channel 
for transmitting the data and sends an active start airlink record to the accounting 
controller. Meanwhile, more data is received by the data network for sending to the 
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wireless communication network. The accounting controller increments the octet 
count by the amount of data received (T4). 

Some time later, the mobile station goes dormant and an active stop airlink 
record is sent to the accounting controller identifying the amount of time the active 
5 traffic channel was utilized. The accounting controller increments the total active 
time by the time the active traffic channel was utilized (T5). 

When an interim timer expires, an interim record is sent to the accounting 
server with the octet count and the total amount of time active. The accounting 
controller then zeroes out the octet count and the total amount of time active (T6). 

1 0 Then, at some time (Tn), the PPP session is closed and a stop record is sent 

with the octet count and total active time to the accounting server. Thus, with the 
preferred embodiment of the present invention, only three accounting messages are 
sent to the accounting server rather than six, as would be required by the first 
embodiment of the present invention as shown in Figure 11. Thus, the preferred 

1 5 embodiment of the present invention reduces the number of accounting messages to 
half. 

When a wireless communication network/data network connection is 
established, a session identifier is generated to identify this connection. One session 
identifier may be used with multiple IP addresses in the data network. Thus, a 

2 0 different UDR is created for each IP address. On the arrival of any airlink record, the 
accounting controller matches the airlink record with the UDR(s) based on the session 
identifier and the IP address. 

With reference back to Figure 8, when the wireless communication 
network/data network connection is established, information is sent to the accounting 

2 5 controller that allows the following fields in the new UDR to be filled: Al, A2, A3, 
A4, CI, D3 and D4. After IP service has been established for a mobile station, the 
following UDR fields are filled by the accounting controller: Bl, B2, Dl, D2, F2, F3, 
HI, II, 12 and 13. The remainder of the UDR is considered blank. 
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When a wireless communication network/data network connection is torn 
down, the UDR fields G6 and G7 are set based on the system date and time and a stop 
record is sent to the accounting server based on the UDR. The UDR is then deleted. 

When user data is received by the bridge server in a forward direction, the 
5 accounting controller increments Gl by the number of octets of data received. When 
user data is received by the bridge server in a reverse direction, the accounting 
controller increments G2 by the number of octets of data received. 

When an active start airlink record is received by the accounting controller, if 
the UDR is a new UDR (partially blank), the following fields of the UDR are set 
1 0 based on the corresponding fields (el, fl, g4, g5 and i4) in the active start airlink 
record: El , Fl, G4, G5 and 14. If the UDR is not a new UDR and the airlink start 
record indicates that parameters in the UDR have changed, a stop record is sent to the 
accounting server based on the current UDR, the UDR fields are set according to their 
corresponding fields in the airlink start record, and the fields G1-G12 are zeroed. A 
1 5 start record is then sent to the accounting server based on the UDR as modified by the 
airlink start record. 

If an SDB airlink record is received, and the field f4 in the SDB airlink record 
indicates that the mobile station terminated the transmission, the field G9 is 
incremented by the value of the corresponding field (g9) in the SDB airlink record. 
2 0 The field Gl 1 is incremented by 1 . If the SDB airlink record indicates that the 

mobile station originated the transmission, the field G10 is incremented by the value 
of the corresponding field (g9) in the SDB airlink record and G12 is incremented by 
1. 

If an airlink stop record is received, the accounting controller increments field 

2 5 G8 by the value of the corresponding field (g8) in the airlink stop record. 

Figure 13 is a flowchart outlining an exemplary operation of the present 
invention. As shown in Figure 13, the operation starts with a determination as to 
whether or not a session has been started (step 1301). If not, the operation continues 
to monitor for a start of a session. If a session has been started, a start message is sent 

3 0 to the accounting server based on the UDR (step 1302). 



Docket No. 11440RRUS02U 



24 



Express Mail No. EL356874475US 



A determination is then made as to whether an SDB airlink record has been 
received (step 1303). If an SDB airlink record has been received, a determination is 
made as to whether the SDB airlink record was received from an originating mobile 
station or a terminating mobile station (step 1304). If the SDB airlink record is from 
5 an originating mobile station, the SDB forward octet count is incremented by the 

amount of the octets in the SDB airlink record (step 1305). If the SDB airlink record 
is from a terminating mobile station, the SDB reverse octet count is incremented by 
the amount of the octets in the SDB airlink record (step 1306). Thereafter, or if an 
SDB airlink record is not received, the operation continues to step 1307. 

10 A determination is made as to whether an airlink start record has been 

received (step 1307). If an airlink start record has been received, a determination is 
made as to whether the user zone has changed (step 1308). If the user zone has 
changed, a stop message is sent to the accounting server based on the current UDR, 
the user zone is updated in the UDR, the connect time and all counts in the UDR are 

1 5 cleared, and a start message is sent to the accounting server based on the new UDR 
(step 1309). Thereafter, or if the user zone has not changed or if an airlink start 
record has not been received, the operation continues to step 1310. 

A determination is made as to whether an airlink stop record has been 
received (step 1310). If an airlink stop record has been received, a connect time is 

2 0 incremented (step 1311). Thereafter, or if an airlink stop record has not been 

received, a determination is made as to whether the session has been terminated (step 
1312). If the session has not been terminated, the operation returns to step 1303. If 
the session has been terminated, a stop message is sent to the accounting server based 
on the UDR (step 1314) and the operation ends. 

2 5 With the present invention, the number of accounting messages sent to an 

accounting server is greatly reduced. This results in less traffic over the network, less 
computing time required by the accounting server and a lower risk of creating race 
conditions. 

It is important to note that, while the present invention has been described in 

3 0 the context of a fully functioning data processing system, those of ordinary skill in the 
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art will appreciate that the processes of the present invention are capable of being 
distributed in the form of a computer readable medium of instructions and a variety of 
forms, and that the present invention applies equally regardless of the particular type 
of signal bearing media actually used to carry out the distribution. Examples of 
computer readable media include recordable-type media such a floppy disc, a hard 
disk drive, a RAM, and CD-ROMs and transmission-type media such as digital and 
analog communications links. 

The description of the present invention has been presented for purposes of 
illustration and description but is not intended to be exhaustive or limited to the 
invention in the form disclosed. Many modifications and variations will be apparent 
to those of ordinary skill in the art. The embodiment was chosen and described in 
order to best explain the principles of the invention and the practical application, and 
to enable others of ordinary skill in the art to understand the invention for various 
embodiments with various modifications as are suited to the particular use 
contemplated. 
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CLAIMS: 

What is claimed is: 

1 1 . A method to optimize accounting records in a wireless/packet data network, 

2 comprising the steps of: 

3 detecting that a communication link has been established between a mobile 

4 terminal and a host in a packet data network; and 

5 accumulating, at a packet data serving node disposed between the mobile 

6 terminal and the packet data network, accounting information relating to a wireless 

7 communication network serving the mobile terminal and the packet data network, the 

8 accounting information being used by service providers to generate billing data to 

9 minimize the frequency of producing accounting records by the packet data serving 
10 node. 

1 2. The method of claim 1, wherein the accounting information includes first 

2 accounting information obtained from one or more base station controllers in the 

3 wireless communication network and second accounting information maintained by 

4 the packet data serving node for the packet data network. 

1 3. The method of claim 1, further comprising: 

2 sending the accounting information to an accounting server based on the 

3 occurrence of a predetermined event. 

1 4. The method of claim 3, wherein the accounting server is a Remote 

2 Authentication Dial-In User Service (RADIUS) server. 

1 5. The method of claim 2, further comprising: 

2 merging the first accounting information and the second accounting 

3 information into a usage data record (UDR). 



Docket No. 11440RRUS02U 



27 



Express Mail No. EL356874475US 



1 6. The method of claim 1 , wherein accounting information relating to a wireless 

2 communication network is obtained from accounting messages sent from the wireless 

3 communication network. 

1 7. The method of claim 6, wherein the accounting messages sent from the 

2 wireless communication network include one or more of a connection setup airlink 

3 record, a connection release airlink record, an active start airlink record, an active 

4 stop airlink record, and a short data burst airlink record. 

1 8. The method of claim 3, wherein the predetermined event is receipt of a 

2 session release airlink record from the wireless communication network. 

1 9. The method of claim 3, wherein the predetermined event is receipt of an 

2 active stop airlink record. 

1 10. The method of claim 3, wherein the predetermined event is receipt of a short 

2 data burst stop airlink record. 

1 11. The method of claim 1 , wherein the accounting information is accumulated 

2 over a series of short data bursts. 

1 12. The method of claim 1, wherein the accounting information is accumulated 

2 over a series of active traffic channel transmissions. 

1 13. The method of claim 1, wherein the accounting information includes the 

2 number of octets of data received from the mobile terminal and the number of octets 

3 sent to the mobile terminal. 

1 14. The method of claim 13, wherein the number of octets of data received from 

2 the mobile terminal and the number of octets sent to the mobile terminal further 
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3 includes the number of octets received from the mobile terminal in the form of short 

4 data bursts and the number of octets sent to the mobile terminal in the form of short 

5 data bursts. 

1 15. The method of claim 1 , wherein the accounting information includes a number 

2 of short data bursts. 

1 16. The method of claim 3, wherein the predetermined event is the expiration of 

2 an interim timer. 

1 17. The method of claim 1, further comprising: 

2 generating a session identifier, wherein the accounting information is 

3 accumulated based on the session identifier. 

1 18. The method of claim 1 , wherein the accounting information is associated with 

2 a session having multiple IP addresses and wherein accounting information for the 

3 wireless communication network and the packet data network are accumulated based 

4 on a session identifier and an IP address from the multiple IP addresses. 

1 19. An accounting apparatus for optimizing accounting records in a 

2 wireless/packet data network, the accounting apparatus being coupled to a wireless 

3 communication network and a packet data network, the apparatus comprising: 

4 a network interface; and 

5 an accounting controller coupled to the network interface, wherein the 

6 accounting controller accumulates accounting information relating to the wireless 

7 communication network, received via the network interface, and accounting 

8 information relating to the packet data network. 

1 20. The apparatus of claim 1 9, wherein the accounting information includes first 

2 accounting information obtained from one or more base station controllers in the 
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3 wireless communication network and second accounting information maintained by 

4 the accounting apparatus for the packet data network. 

1 21. The apparatus of claim 1 9, wherein the accounting controller sends the 

2 accounting information to an accounting server based on the occurrence of a 

3 predetermined event. 

1 22. The apparatus of claim 21 , wherein the accounting server is a Remote 

2 Authentication Dial-In User Service (RADIUS) server. 

1 23 . The apparatus of claim 20, wherein the accounting controller merges the first 

2 accounting information and the second accounting information into a usage data 

3 record (UDR). 

1 24. The apparatus of claim 19, wherein the accounting controller receives the 

2 accounting information relating to a wireless communication network from 

3 accounting messages sent from the wireless communication network. 

1 25. The apparatus of claim 24, wherein the accounting messages sent from the 

2 wireless communication network include one or more of a connection setup airlink 

3 record, a connection release airlink record, an active start airlink record, an active 

4 stop airlink record, and a short data burst airlink record. 

1 26. The apparatus of claim 2 1 , wherein the predetermined event is receipt of a 

2 session release airlink record from the wireless communication network. 

1 27. The apparatus of claim 21, wherein the predetermined event is receipt of an 

2 active stop airlink record. 
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1 28. The apparatus of claim 21 , wherein the predetermined event is receipt of a 

2 short data burst stop airlink record. 

1 29. The apparatus of claim 1 9, wherein the accounting controller accumulates the 

2 accounting information over a series of short data bursts. 

1 30. The apparatus of claim 19, wherein the accounting controller accumulates the 

2 accounting information over a series of active traffic channel transmissions. 

1 31. The apparatus of claim 1 9, wherein the accounting information includes the 

2 number of octets of data received from a mobile terminal and the number of octets 

3 sent to the mobile terminal. 

1 32. The apparatus of claim 31, wherein the number of octets of data received from 

2 the mobile terminal and the number of octets sent to the mobile terminal further 

3 includes the number of octets received from the mobile terminal in the form of short 

4 data bursts and the number of octets sent to the mobile terminal in the form of short 

5 data bursts. 

1 33. The apparatus of claim 19, wherein the accounting information includes a 

2 number of short data bursts. 

1 34. The apparatus of claim 21, wherein the predetermined event is the expiration 

2 of an interim timer. 

1 35. A computer program product in a computer readable medium for optimizing 

2 accounting records in a wireless/packet data network, comprising: 

3 first instructions for detecting that a communication link has been established 

4 between a mobile terminal and a host in a packet data network; and 
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5 second instructions for accumulating, at a packet data serving node disposed 

6 between the mobile terminal and the packet data network, accounting information 

7 relating to a wireless communication network serving the mobile terminal and the 

8 packet data network, the accounting information being used by service providers to 

9 generate billing data to minimize the frequency of producing accounting records by 
1 0 the packet data serving node. 

1 36. The computer program product of claim 3 5 , wherein the accounting 

2 information includes first accounting information obtained from one or more base 

3 station controllers in the wireless communication network and second accounting 

4 information maintained by the packet data serving node for the packet data network. 

1 37. The computer program product of claim 35, further comprising: 

2 third instructions for sending the accounting information to an accounting 

3 server based on the occurrence of a predetermined event. 

1 38. The computer program product of claim 36, further comprising: 

2 third instructions for merging the first accounting information and the second 

3 accounting information into a usage data record (UDR). 

1 39. The computer program product of claim 35, wherein accounting information 

2 relating to a wireless communication network is obtained from accounting messages 

3 sent from the wireless communication network, and wherein the accounting messages 

4 sent from the wireless communication network include one or more of a connection 

5 setup airlink record, a connection release airlink record, an active start airlink record, 

6 an active stop airlink record, and a short data burst airlink record. 

1 40. The computer program product of claim 37, wherein the predetermined event 

2 is receipt of one of a session release airlink record from the wireless communication 

3 network, an active stop airlink record, and a short data burst stop airlink record. 
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1 41. The computer pro gram product of claim 3 5 , wherein the accounting 

2 information is accumulated over a series of short data bursts 

1 42. The computer program product of claim 35, wherein the accounting 

2 information is accumulated over a series of active traffic channel transmissions. 
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ABSTRACT OF THE DISCLOSURE 



METHOD AND APPARATUS FOR MERGING ACCOUNTING RECORDS TO 
MINIMIZE OVERHEAD 



A method and apparatus for merging accounting records to minimize 
overhead is provided. The method and apparatus accumulate accounting information 
for data transmissions between a wireless communication device and a host on a data 

1 0 network. The method and apparatus are capable of accumulating accounting 

information for short data bursts and for active traffic channel transmissions such that 
an accounting messages is sent to an accounting server only when transitions from 
short data burst transmission or active traffic channel transmission to another state are 
encountered. Thus, accounting information for a plurality of sequential short data 

15 bursts and/or active traffic channel transmissions are accumulated. This reduces the 
number of accounting messages sent to an accounting server and eliminates race 
conditions that may be encountered by sequential short data bursts. 
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integer 


v f8 


Fundamental Frame Size (5/20 ms) 


1 


integer 


v f9 


Forward Fundamental RC 


1 


integer 


, f10 


Reverse Fundamental RC 


1 


integer 


v i4 


Airlink Quality of Service (QoS) 




integer 
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Item 


Parameter 


Max Payload 
Lenath 


Format 




Airlink Record TvDe = Y4 (Active StoD) 




inteaer 




R-P Session ID 


4 


strina 










. 9 s 


Active Connection Time in Seconds 


4 


integer 
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Item 


Parameter 


Max Payload 


Format 




Airlink Record Tvoe = SDB 


1 


inteaer 




R-P Session ID 


4 


strinq 


f4 


Mobile Originated/Mobile Terminated Indicator 






1 gio 


SDB Octet Count 


4 


integer 
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Item 1 Parameter 1 DescriDtion 1 


A. Mobi 


e Identifiers 


A1 


MSID I I 


B. User 


dentifiers 


B1 


IP Address 


IP address of the mobile station. 


B2 


Network Access 
Identifier (NAD 


user@domain construct which identifies the user and home network of the mobile 


C. Session Identifiers 


C1 


Account Session 
ID 


A unique accounting ID ID created by the PDSN that allows stop and start records to be 
matched in a loq file. 


C2 


Correlation ID 


An ID that correlates all accounting sessions authorized for this NAI by this access 
request 


D. Infras 


tructure Identifiers 


D1 


MIP Home Agent 
(HA) 


The IP address of the HA 


D2 


PDSN/FA 
Address 


IP address or other identifier. 


D3 


Servina PCF 


The IP address of the servinq PCF 


D4 


BS/MSCID 


The IP address of the BS/MSC. 








E. Zone 


dentifiers 


E1 IllserZone iTiered Services user zone. 


F. Sessi 


on Status 








F1 


Forward Mux 
Option 




F2 


Reverse Mux 
Option 




F3 


Forward 

Fundamental Rate 




F4 


Reverse 

Fundamental Rate 




F5 


Service Option 




F6 


Forward Traffic 
Type 


Primary and Secondary 


F7 


Reverse Traffic 
Type(Primary, 
Secondary) 


Primary and Secondary 


F8 


Fundamental 
Frame Size 


The fundamental channel hs the choice of 5 or 20 ms size. The 5ms frame sized 
comes from the DCCH (dedicated signalig channel) concept and allows fast response 
fro short siqnalinq messaqes (short frame can be decoded ouicklv). 


F9 


Forward 

Fundamental RC 




F10 


Reverse 

Fundamental RC 




F11 


IP Technoloqv 


Indentifies Simple IP. Mobile IP. or another technoloov. 


F12 


Compulsory 
Tunnel Indicator 


Indicator of invocation of compulsory tunnel established on behalf of MS for providing 
private network and/or ISP access durinq a sinole packet data connection. 


F13 


Release Indicator 


Specifies reason for sending a stop record. 


G. Sess 


on Activity 


G1 


Data Octet Count 
(Terminatinq) 


total # of octets sent to the user. 


G2 


Data Octet Count 
(Oriqinatinq) 


total # of octets sent by the user. 


G3 


Bad PPP frame 
count 


total # PPP frames from the mobile stationdropped by PDSN due to uncorrectable 
errors. 


G4 


Event Time 


Indicates start of accounting session or stop of accounting session if part of a RADIUS 
start message or stop message, respectively. It is also used in a RADIUS interim 
messaoe to indicate the time of the event which trioaered the interim messaoe. 


G8 


Active Time 


The total active connection time on traffic channel in seconds. 



Figure 8A 

11440RRUS02U 
Sheet 6 of 12 



Express Mail No. EL356874475US 



G9 


Number of Active 
Transitions 


The total number of non-active to Active transitions by the user. 


G10 


SDB Octet Count 
(Terminating) 


The total number of octets sent to the user via Short Data Bursts. 


G11 


SDB Octet Count 
(Originating) 


The total number of octets sent bv the user via Short Data Bursts. 


G12 


Number of SDBs 
(Terminating) 


The total number of Short Data Burst transactions. 


G13 


Number of SDBs 
(Originating) 


The total number of Short Data Burst transactions. 


H. Soec 


al Billina Instructic 


ns 


H1 


Alternate Billing 
Identifier 


An IP address or other identifier of alternate entity for which data session usage may be 
billed. 


1. Qualit 


/ of Service 


11 


IP Quality of 
Service (QoS) 


The home RADIUS server authorizes the mobile to mark packets (only) with these 
Differentiated Services code points. 


12 


Interconnection IP 
Network Provider 
ID 


Identifies IP network which connects wireless carrier network to destination. 


13 


Interconnecting IP 
Network Service 
Quality of Service 


Identifies QoS offered by IP network which connects wireless carrier network to 
destination. 


14 


Airlink Quality of 
Service (QoS) 


Identifies airlink QoS 
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Time 


Wireless Communication Network 


Accounting Controller 


1 


MS is dormant 


2 




Network originated data enters DN and sent to WCN 
- octet_count incremented 


3 


SDB is being transmitted over the air 


More network data enters DN and sent to WCN 
- octet_count incremented 


4 


- Airlink record (SDB, sdb_octets1) sent 


- start and stop records sent to acct. server using sdb_octets1 

- octet_count decremented by sdb_octets1 


5 


RN decides to put MS on traffic channel 
- Active start airlink record sent 


- start record sent to acct. server 








0 


MS goes dormant 

— Active stop airlink record sent 


- stop record sent to acct. server with octet_count 

— octet count zeroed 
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Time 


Wireless Communication Network 


Accounting Controller 


1 


MS is dormant 


2 




Network originated data enters DN and sent to WCN 
— octet_count incremented 


3 


SDB1 is being transmitted over the air 


More network data enters DN and sent to WCN 
- octet_count incremented 


4 


SDB2 is being transmitted over the air 
- Airlink record (SDB1 , sdb_octets1) sent 


More network data enters DN and sent to WCN 

- increments num_SDBs by 1, and total_SDB_octets by 
sdb_octets1 

- octet_count incremented 


5 


SDB3 is being transmitted over the air 
- Airlink record (SDB2, sdb_octets2) sent 


More network data enters DN and sent to WCN 

- PDSN increments num_SDBs by 1, and total_SDB_octets 

by sdb_octets2 

-- octet_count incremented 


6 




Interim timer expires 

— start and stop records sent to acct. server using num_SDBs, 
total_SDB_octets and octet_count 

- Clear num_SDBs, total_SDB_octets and octet_count 


7 


- Airlink record (SDB3, sdb_octets3) sent 


More network data enters DN and sent to WCN 

- increments num_SDBs by 1, and total_SDB_octets by 
sdb_octets3 

- octet_count incremented 


8 


WCN decides to put MS on traffic channel 
— Active start airlink record sent 


More network data enters DN and sent to WCN 
~ start record sent to acct. server with num_SDBs, 
total_SDB_octets and octet_count 
- octet_count incremented 










MS goes dormant 

-- Active stop airlink record sent 


- stop record sent to acct. server with num_SDBs, 

total_SDB_octets and octet_count 

~ Clear num_SDBs, total_SDB_octets and octet_count 
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Time 


Wireless Communication Network 


Accounting Controller 




MS is dormant 


2 




Network originated data enters DN and sent to WCN 
— octet_count incremented 


3 


WCN decides to put MS on traffic channel 
Active start airlink record sent 


Network originated data enters DN and sent to WCN. 

— start record sent to acct. server 

— octet_count incremented 




MS goes dormant 

- Active stop airlink record sent 


— stop record sent to acct. server using octet_count 

— octet_count zeroed 


5 




Network originated data enters DN and sent to WCN. 
-octet count incremented 


6 


WCN decides to put MS on traffic channel 
Active start airlink record sent 


- start record sent to acct. server 


7 


MS goes dormant 

- Active stop airlink record sent 


- stop record sent to acct. server with octet_count 

- octet_count zeroed 



Figure 1 1 
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Time 


Wireless Communication Network 


Accounting Controller 


1 


WCN decides to put MS on traffic channel and 

new PPP is established 

Active start airlink record (new PPP) sent 


— start record sent to acct. server 


2 


MS goes dormant 

— Active stop airlink record (active_time1) sent 


-- increment total_active_time by active_time1 


3 




Network originated data enters DN and sent to WCN. 
- octet_count incremented 


4 


WCN decides to put MS on traffic channel 
Active start airlink record sent 


Network originated data enters DN and sent to WCN. 
- octet_count incremented 


5 


MS goes dormant 

— Active stop Airlink record (active_time2) sent 


increment total_active_time by active_time2 


6 




interim timer expires 

- interim record sent to acct. server with octet_count and 
total_active_time 

— octet_count and total_active_time zeroed 












PPP Session is closed (timeout) 

-- stop record sent to acct. server with octet_count and 

total_active_time 



Figure12 
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